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Foreword 



This Technical Specification has been produced by the 3' Generation Partnership Project (3GPP). 

The contents of the present document are subject to continuing work within the TSG and may change following formal 
TSG approval. Should the TSG modify the contents of the present document, it will be re-released by the TSG with an 
identifying change of release date and an increase in version number as follows: 

Version x.y.z 
where: 

X the first digit: 

1 presented to TSG for information; 

2 presented to TSG for approval; 

3 or greater indicates TSG approved document under change control. 

y the second digit is incremented for all changes of substance, i.e. technical enhancements, corrections, 
updates, etc. 

z the third digit is incremented when editorial only changes have been incorporated in the document. 



Introduction 



The present document is part 8 of a multi-part TS covering the 3' Generation Partnership Project: Technical 
Specification Group Core Network; Open Service Access (OSA); Application Programming Interface (API), as 
identified below. The API specification (3GPP TS 29.198) is structured in the following Parts: 



Parti 
Part 2 
Part 3 
Part 4 



Part 5: 
Part 6: 
Part 7: 
Part 8: 

Part 9: 
Part 10 
Part 11 
Part 12 
Part 13 
Part 14 
Part 15 



"Overview"; 

"Common Data Definitions"; 

"Framework"; 

"Call Control"; 

Sub-part 1: "Call Control Common Definitions"; 

Sub-part 2: "Generic Call Control SCF"; 

Sub-part 3: "Multi-Party Call Control SCF"; 

Sub-part 4: "Multi-Media Call Control SCF"; 

Sub-part 5: "Conference Call Control SCF"; 

"User Interaction SCF"; 

"Mobility SCF"; 

"Terminal Capabihties SCF"; 

"Data Session Control SCF"; 

"Generic Messaging SCF"; 

"Connectivity Manager SCF"; 

"Account Management SCF"; 

"Charging SCF". 

"Policy Management SCF"; 

"Presence and Availability Management SCF"; 

"Multi Media Messaging SCF"; 



(not part of 3GPP Release 6) 



(not part of 3GPP Release 6) 
(not part of 3GPP Release 6) 



(new in Release 6) 



The Mapping specification of the OSA APIs and network protocols (3GPP TR 29.998) is also structured as above. 
A mapping to network protocols is however not applicable for all Parts, but the numbering of Parts is kept. 
Also in case a Part is not supported in a Release, the numbering of the parts is maintained. 
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Table: Overview of the OSA APIs & Protocol Mappings 29.198 & 29.998-faniily 



OSA API specifications 29.198-family 


OSA API Mapping - 29.998-family 


29.198-01 


Overview 


29.998-01 


Overview 


29.198-02 


Common Data Definitions 


29.998-02 


Not Applicable 


29.198-03 


Framework 


29.998-03 


Not Applicable 


Call 
Control 
(CC) SCF 


29.198- 
04-1 

Common 
CC data 
definitions 


29.198- 
04-2 
Generic 
CCSCF 


29.198- 
04-3 
Multi- 
Party CC 
SCF 


29.198- 
04-4 
Multi- 
media CC 
SCF 


29.998-04-1 


Generic Call Control - CAP mapping 


29.998-04-2 


Generic Call Control - INAP mapping 


29.998-04-3 


Generic Call Control - Megaco mapping 


29.998-04-4 


Multiparty Call Control - ISC mapping 


29.198-05 


User Interaction SCF 


29.998-05-1 


User Interaction - CAP mapping 


29.998-05-2 


User Interaction - INAP mapping 


29.998-05-3 


User Interaction - Megaco mapping 


29.998-05-4 


User Interaction - SMS mapping 


29.198-06 


Mobility SCF 


29.998-06 


User Status and User Location - MAP mapping 


29.198-07 


Terminal Capabilities SCF 


29.998-07 


Not Applicable 


29.198-08 


Data Session Control SCF 


29.998-08 


Data Session Control - CAP mapping 


■ 29.198-09 


Generic Messaging SCF 


29.998-09 


Not Applicable 


29.198-10 


Connectivity Manager SCF 


29.998-10 


Not Applicable 


29.198-11 


Account Management SCF 


29.998-11 


Not Applicable 


29.198-12 


Charging SCF 


29.998-12 


Not Applicable 


29.198-13 


Policy Management SCF 


29.998-13 


Not Applicable 


29.198-14 


Presence & Availability Management SCF 


29.998-14 


Not Applicable 


29.198-15 


Multi-media Messaging SCF 


29.998-15 


Not Applicable 
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Scope 



The present document is Part 8 of the Stage 3 specification for an Apphcation Programming Interface (API) for Open 
Service Access (OS A). 

The OSA specifications define an architecture that enables application developers to make use of network functionality 
through an open standardised interface, i.e. the OSA APIs. The concepts and the functional architecture for the OSA are 
contained in 3GPP TS 23.198 [3]. The requirements for OSA are contained in 3GPP TS 22.127 [2]. 

The present document specifies the Data Session Control Service Capability Feature (SCF) aspects of the interface. All 
aspects of the Data Session Control SCF are defined here, these being: 

Sequence Diagrams 

Class Diagrams 

Interface specification plus detailed method descriptions 

State Transition diagrams 

Data definitions 

IDL Description of the interfaces 

WSDL Description of the interfaces 

The process by which this task is accomplished is through the use of object modelling techniques described by the 
Unified ModelUng Language (UML). 

This specification has been defined jointly between 3GPP TSG CT WG5, ETSI TISPAN and the Parlay Group, in co- 
operation with a number of JAIN^"^ Community member companies. 



References 



The following documents contain provisions which, through reference in this text, constitute provisions of the present 
document. 

• References are either specific (identified by date of publication, edition number, version number, etc.) or 
non-specific. 

• For a specific reference, subsequent revisions do not apply. 

• For a non-specific reference, the latest version applies. In the case of a reference to a 3GPP document (including 
a GSM document), a non-specific reference implicitly refers to the latest version of that document in the same 
Release as the present document. 

[1] 3GPP TS 29.198-1 "Open Service Access; Application Programming Interface; Part 1: Overview". 

[2] 3GPP TS 22. 127: "Service Requirement for the Open Services Access (OSA); Stage 1 ". 

[3] 3GPP TS 23.198: "Open Service Access (OSA); Stage 2". 

[4] ISO 4217: "Codes for the representation of currencies and funds". 
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3.1 



Definitions and abbreviations 



Definitions 



For the purposes of the present document, the terms and definitions given in TS 29.198-1 [1] apply. 

3.2 Abbreviations 

For the purposes of the present document, the abbreviations given in TS 29.198-1 [1] apply. 



4 Data Session Control SCF 

The Data Session Control network SCF consists of two interfaces: 

1) Data Session manager, containing management functions for data session related issues; 

2) Data Session, containing methods to control a session. 

A session can be controlled by one Data Session Manager only. Data Session Manager can control several sessions. 



Data Session 
Manager 



1 n 



Data Session 



NOTE: The term "data session" is used in a broad sense to describe a data connection/session. For example, it 
comprises a PDP context in GPRS. 

Figure 1 : Data Session control interfaces usage relationship 

The Data Session Control SCFs are described in terms of the methods in the Data Session Control interfaces. Table 1 
gives an overview of the Data Session Control methods and to which interfaces these methods belong. 

Table 1 : Overview of Data Session Control interfaces and their methods 



Data Session IVIanager 


Data Session 


createNotification 


connectReq 


destroyNotification 


connectRes 


dataSessionNotificationlnterrupted 


connectErr 


dataSessionNotificationContinued 


release 


reportNotification 


superviseDataSessionReq 


dataSessionAborted 


superviseDataSessionRes 


getNotifications 


superviseDataSessionErr 


cliangeNotification 


dataSessionFaultDetected 


enableNotifications 


setAdviceofCharge 


disableNotifications 


setDataSessionChargePlan 



The session manager interface provides the management functions to the data session service capability features. The 
application programmer can use this interface to enable or disable data session-related event notifications. 

The following clauses describe each aspect of the Data Session Control Service Capability Feature (SCF). 

The order is as follows: 

• the Sequence diagrams give the reader a practical idea of how each of the SCF is implemented; 

• the Class relationships clause shows how each of the interfaces applicable to the SCF, relate to one another; 

• the Interface specification clause describes in detail each of the interfaces shown within the Class diagram part; 
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• the State Transition Diagrams (STD) show the transition between states in the SCF. The states and transitions 
are well-defined; either methods specified in the Interface specification or events occurring in the underlying 
networks cause state transitions; 

• the Data definitions clause shows a detailed expansion of each of the data types associated with the methods 
within the classes. Note that some data types are used in other methods and classes and are therefore defined 
within the Common Data types part of this specification. 

4.1 General requirements on support of methods 

An implementation of this API which supports or implements a method described in the present document, shall 
support or implement the functionality described for that method, for at least one valid set of values for the parameters 
of that method. 

Where a method is not supported by an implementation of a Service interface, the exception 
P_METHOD_NOT_SUPPORTED shall be returned to any call of that method. 

Where a method is not supported by an implementation of an Application interface, a call to that method shall be 
possible, and no exception shall be returned. 



5 Sequence Diagrams 

5.1 Network Controlled Notifications 

The following sequence diagram shows how an application can receive notifications that have not been created by the 
application, but are provisioned from within the network. 
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AppLogic 



IpAppDataSessionControlManager 

I 

1 : new ( ) 



IpDataSessionControlManager 



^ 



2: e|nableNoti1ications( ) 



-^[ 



4: 'forward event' 



[T 



3: reportNotification( 



^<r 



6: 'forward event' 



(f- 



5: reportNotification{ 



h^- 



7: disableNotifications{ ) 



->i 



1: The application is started. The apphcation creates a new IpAppDataSessionControlManager to handle callbacks. 

2: The enableNotifications method is invoked on the IpDataSessionControlManager interface to indicate that the 
application is ready to receive notifications that are created in the network. For illustrative purposes we assume 
notifications of type "B" are created in the network. 

3: When a network created trigger occurs the application is notified on the callback interface. 

4: The event is forwarded to the application. 

5: When a network created trigger occurs the application is notified on the callback interface. 

6: The event is forwarded to the application. 

7: When the application does not want to receive notifications created in the network anymore, it invokes 
disableNotifications on the IpDataSessionControlManager interface. From now on the gateway will not send any 
notifications to the application that are created in the network. The application will still receive notifications that it has 
created itself until the application removes them. 



5.2 



Enable Data Session Notification 
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Application 



Data Session IVIanager : 
IpDataSessionControllVlanager 



1: createNotification( ) 



^ 



Data Session : 
IpDataSession 



5.3 Address Translation With Charging 
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Application 



Data Session Manager : 
IpDataSessionControlManager 



1 : createNotification( ) 



3: 'translate address' 
^< — ^ 



2: reportNotificationO 



1^ 



1^ 



^^ 



4: setGallback( ) 



5: superviseDataSessionReq( 



6: connectReq( 



7: superviseDataSessionResQ 



8: superviseDa^aSessionReq( 



9: SuperviseDataSessionResQ 



10: Con|iectRes( ) 



Data Session : 
IpDataSession 



->! 



->, 



->, 



->r 



6 Class Diagrams 



Data Session Control Class Diagram: 
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«lnterface» 
Iplnterface 

(fromcsapi) 



«lnterface» 
IpAppDataSessionControlManager 

(from dsc) 



l^dataSessionAbortedO — 

l^reportNotificationO 1 

l^dataSessionNotificationContinuedO 
l^dataSessionNotificationlnterruptedO 
U«new» aborlMultipleDataSessionsO 



«uses» 



«lnterface» 
IpDataSessionControlManager 

(from dsc) 



|«deprecated» createNotification() 
lestroyNotificationO — 

BchangeNotificationO 1 

■enableNotificationsO 
^disableNotificationsO 
^getNotificationsO 
^createNotificationsO 



«lnterface» 
IpAppDataSession 

(from dsc) 



^connectResO 
0..ri ^connectErrQ 

%uperviseDataSessionRes() 

%uperviseDataSessionErr() 

^dataSessionFaultDetectedO 



«uses» 



«lnterface» 
IpDataSession 

(from dsc) 



r^connectReqO 
%elease() 
0..n ^superviseDataSessionReqO 
. '^setDataSess ionChargePlanC 
l^setAdviceOChargeO 
J^deassign DataSession() 
l^continueProcessingO 



«lnterface» 
IpService 

(from csapi) 



►setCallbackO 
^setCallbackWithSessionlDO 



Figure: Package Overview 
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7 The Service Interface Specifications 

7.1 Interface Specification Format 

This clause defines the interfaces, methods and parameters that form a part of the API specification. The Unified 
Modelling Language (UML) is used to specify the interface classes. The general format of an interface specification is 
described below. 

7.1.1 Interface Class 

This shows a UML interface class description of the methods supported by that interface, and the relevant parameters 
and types. The Service and Framework interfaces for enterprise-based client applications are denoted by classes with 
name Ip<name>. The callback interfaces to the applications are denoted by classes with name IpApp<name>. For 
the interfaces between a Service and the Framework, the Service interfaces are typically denoted by classes with name 
IpSvc<name>, while the Framework interfaces are denoted by classes with name IpFw<name>. 

7.1.2 Method descriptions 

Each method (API method "call") is described. Both synchronous and asynchronous methods are used in the API. 
Asynchronous methods are identified by a 'Req' suffix for a method request, and, if applicable, are served by 
asynchronous methods identified by either a 'Res' or 'Err' suffix for method results and errors, respectively. To handle 
responses and reports, the application or service developer must implement the relevant IpApp<name> or 
IpSvc<name> interfaces to provide the callback mechanism. 

7.1.3 Parameter descriptions 

Each method parameter and its possible values are described. Parameters described as 'in' represent those that must have 
a value when the method is called. Those described as 'out' are those that contain the return result of the method when 
the method returns. 

7.1.4 State Model 

If relevant, a state model is shown to illustrate the states of the objects that implement the described interface. 

7.2 Base Interface 

7.2.1 Interface Class Iplnterface 

All application, framework and service interfaces inherit from the following interface. This API Base Interface does not 
provide any additional methods. 
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«lnterface» 
Iplnterface 



7.3 Service Interfaces 
7.3.1 Overview 

The Service Interfaces provide the interfaces into the capabilities of the underlying network - such as call control, user 
interaction, messaging, mobility and connectivity management. 

The interfaces that are implemented by the services are denoted as "Service Interface". The corresponding interfaces 
that must be implemented by the application (e.g. for API callbacks) are denoted as "Application Interface". 

7.4 Generic Service Interface 
7.4.1 Interface Class IpService 

Inherits from: Iplnterface 

All service interfaces inherit from the following interface. 



«lnterface» 
IpService 



setCallback (applnterface : in IplnterfaceRef) : void 

setCallbackWitlnSessionID (applnterface : in IplnterfaceRef, sessionID : in TpSessionID) : void 



7.4.1.1 Method setCallback() 

This method specifies the reference address of the callback interface that a service uses to invoke methods on the 
application. It is not allowed to invoke this method on an interface that uses SessionlDs. Multiple invocations of this 
method on an interface shall result in multiple callback references being specified. The SCS shall use the most recent 
callback interface provided by the application using this method. In the event that a callback reference fails or is no 
longer available, the next most recent callback reference available shall be used. 

Parameters 

applnterface : in IplnterfaceRef 

Specifies a reference to the application interface, which is used for callbacks. 

Raises 

TpCommonExceptions , P_INVALID_INTERFACE_TYPE 
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7.4.1.2 Method setCallbackWithSessionlD() 

This method specifies the reference address of the application's callback interface that a service uses for interactions 
associated with a specific session ID: e.g. a specific call, or call leg. It is not allowed to invoke this method on an 
interface that does not use SessionlDs. Multiple invocations of this method on an interface shall result in multiple 
callback references being specified. The SCS shall use the most recent callback interface provided by the application 
using this method. In the event that a callback reference fails or is no longer available, the next most recent callback 
reference available shall be used. 

Parameters 

applnterface : in IpInterfaceRef 

Specifies a reference to the application interface, which is used for callbacks. 

sessionID : in TpSessionID 

Specifies the session for which the service can invoke the application's callback interface. 

Raises 

TpCommonExceptions, P_INVALID_SESSION_ID, P_INVALID_INTERFACE_TYPE 



8 Data Session Control Interface Classes 

The Data Session Control provides a means to control per data session basis the establishment of a new data session. 
This means especially in the GPRS context that the establishment of a PDP session is modelled not the attach/detach 
mode. Change of terminal location is assumed to be managed by the underlying network and is therefore not part of the 
model. The underlying assumption is that a terminal initiates a data session and the application can reject the request for 
data session establishment, can continue the establishment or can continue and change the destination as requested by 
the terminal. 

The modelling is similar to the Generic Call Control but assumes a simpler underlying state model. An 
IpDataSessionControlManager object and an IpDataSession object are the interfaces used by the application, whereas 
the IpAppDataSessionControlManager and the IpAppDataSession interfaces are implemented by the application. 

8.1 Interface Class IpAppDataSession 

Inherits from: Iplnterface. 

The application side of the data session interface is used to handle data session request responses and state reports. 
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«lnterface» 
IpAppDataSession 



connectRes (dataSessionID : in TpSessionID, eventReport : in TpDataSessionReport, assignmentID : in 
TpAssignmentID) : void 

connectErr (dataSessionID : in TpSessionID, errorlndication : in TpDataSessionError, assignmentID : in 
TpAssignmentID) : void 

superviseDataSessionRes (dataSessionID : in TpSessionID, report : in TpDataSessionSuperviseReport, 
usedVolume : in TpDataSessionSuperviseVolume, qualityOf Service : in TpDataSessionQosClass) : void 

superviseDataSessionErr (dataSessionID : in TpSessionID, errorlndication : in TpDataSessionError) : void 

dataSessionPaultDetected (dataSessionID : in TpSessionID, fault : in TpDataSessionFault) : void 



8.1.1 Method connectRes() 



This asynchronous method indicates that the request to connect a data session with the destination party was successful, 
and indicates the response of the destination party (e.g. connected, disconnected). 

Parameters 

dataSessionID : in TpSessionID 

Specifies the session ID of the data session. 

eventReport : in TpDataSessionReport 

Specifies the result of the request to connect the data session. It includes the network event, date and time, monitoring 
mode, negotiated quality of service and event specific information such as release cause. 

assignmentID : in TpAssignmentID 



8.1 .2 Method connectErr() 

This asynchronous method indicates that the request to connect a data session with the destination party was 
unsuccessful, e.g. an error detected in the network or the data session was abandoned. 

Parameters 

dataSessionID : in TpSessionID 

Specifies the session ID. 

errorlndication : in TpDataSessionError 

Specifies the error which led to the original request failing. 

assignmentID : in TpAssignmentID 
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8.1 .3 Method superviseDataSessionResQ 



This asynchronous method reports a data session supervision event to the apphcation. In addition, it may also be used 
to notify the application of a newly negotiated set of Quality of Service parameters during the active life of the data 

session. 

Parameters 

dataSessionID : in TpSessionID 

Specifies the data session. 

report : in TpDataSessionSuperviseReport 

Specifies the situation, which triggered the sending of the data session supervision response. 

usedVolvime : in TpDataSessionSuperviseVolvime 

Specifies the used volume for the data session supervision (in the same unit as specified in the request). 

qualityOfService : in TpDataSessionQosClass 

Specifies the newly negotiated Quality of Service parameters for the data session. 



8.1 .4 Method superviseDataSessionErrQ 

This asynchronous method reports a data session supervision error to the application. 

Parameters 

dataSessionID : in TpSessionID 

Specifies the data session ID. 

errorlndication : in TpDataSessionError 

Specifies the error which led to the original request failing. 



8.1 .5 Method dataSessionFaultDetected() 

This method indicates to the application that a fault in the network has been detected which cannot be communicated by 
a network event, e.g. when the user aborts before any establishment method is called by the application. 

The system purges the Data Session object. Therefore, the application has no further control of data session processing. 
No report will be forwarded to the application. 

Parameters 

dataSessionID : in TpSessionID 

Specifies the data session ID of the Data Session object in which the fault has been detected. 

fault : in TpDataSessionFault 

Specifies the fault that has been detected. 
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8.2 Interface Class IpAppDataSessionControlManager 

Inherits from: Iplnterface. 

The data session control manager application interface provides the application data session control management 
functions to the data session control SCF. 



«lnterface» 
IpAppDataSessionControlManager 



dataSessionAborted (dataSession : in TpSessionID) : void 

reportNotification (dataSessionReference : in TpDataSessionldentifier, eventlnfo : in 
TpDataSessionEventlnfo, assignmentID : in TpAssignmentID) : IpAppDataSessionRef 

dataSessionNotificationContinued () : void 

dataSessionNotificationlnterrupted () : void 

«new» abortMultipleDataSessions (dataSessionSet : in TpSessionlDSet) : void 



8.2.1 Method dataSessionAbortedO 

This method indicates to the application that the Data Session object has aborted or terminated abnormally. No further 
communication will be possible between the Data Session object and the application. 

Parameters 

dataSession : in TpSessionID 

Specifies the session ID of the data session that has aborted or terminated abnormally. 



8.2.2 Method reportNotification() 

This method notifies the application of the arrival of a data session-related event. 

If this method is invoked with a monitor mode of P_DATA_SESSION_MONITOR_MODE_INTERRUPT, then the 
application has control of the data session. If the application does nothing with the data session within a specified time 
period (the duration of which forms a part of the service level agreement), then the data session in the network shall be 
released and dataSessionFaultDetected() shall be invoked, giving a fault code of 
P_DATA_SESSION_TIMEOUT_ON_INTERRUPT. 

Returns appDataSession : Specifies a reference to the application object which implements the callback interface for the 
new data session. If the application has previously explicitly passed a reference to the IpAppDataSession interface using 
a setCallbackWithSessionlDO invocation, this parameter may be null, or if supplied must be the same as that provided 
during the setCallbackWithSessionID(). 

This parameter will be null if the notification is in NOTIFY mode. 

Parameters 

dataSessionReference : in TpDataSessionldentifier 

Specifies the session ID and the reference to the Data Session object to which the notification relates. If the notification 
is being given in NOTIFY mode, this parameter shall be ignored by the application client implementation, and 
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consequently the implementation of the SCS entity invoking reportNotification may populate this parameter as it 
chooses. 

eventlnfo : in TpDataSessionEventlnfo 

Specifies data associated with this event. This data includes the destination address provided by the end-user and the 
quality of service requested or negotiated for the data session. 

assignmentID : in TpAssignmentID 

Specifies the assignment id which was returned by the createNotification() method. The application can use assignment 
ID to associate events with event-specific criteria and to act accordingly. 

Returns 
IpAppDataSessionRef 



8.2.3 Method dataSessionNotificationContinuedQ 

This method indicates to the application that all event notifications are resumed. 

Parameters 

No Parameters were identified for this method 

8.2.4 Method dataSessionNotificationlnterrupted() 

This method indicates to the application that event notifications will no longer be sent (for example, due to faults 
detected). 

Parameters 

No Parameters were identified for this method 

8.2.5 Method «new» abortMultipleDataSessionsQ 

The service may invoke this method on the IpAppDataSessionControlManager interface to indicate that a number of 
ongoing data sessions have aborted or terminated abnormally. No further communication will be possible between the 
application and the data sessions. This may be used for example in the event of service failure and recovery in order to 
instruct the application that a number of data sessions have failed. The service shall provide a set of data sessionlDs 
indicating to the application the data sessions that have aborted. In the case that the service invokes this method and 
provides an empty set of sessionlDs, this shall be used to indicate that all data sessions previously active on the 
IpDataSessionControlManager interface have been aborted. 

Parameters 

dataSessionSet : in TpSessionlDSet 

Specifies the set of sessionlDs of data sessions that have aborted or terminated abnormally. The empty set shall be used 
to indicate that all data sessions have aborted. 



8.3 Interface Class IpDataSession 

Inherits from: IpService. 
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The Data Session interface provides basic methods for applications to control data sessions. This interface shall be 
implemented by a Data Session Control SCF. As a minimum requirement, the connectReqO, release(), 
deassignDataSessionO and continueProcessingO methods shall be implemented. 



«lnterface» 
IpDataSession 



connectReq (dataSessionID : in TpSessionID, responseRequested : in TpDataSessionReportRequestSet, 
targetAddress : in TpAddress) : TpAssignmentID 

release (dataSessionID : in TpSessionID, cause : in TpDataSessionReleaseCause) : void 

superviseDataSessionReq (dataSessionID : in TpSessionID, treatment : in 

TpDataSessionSuperviseTreatment, bytes : in TpDataSessionSuperviseVolume) : void 

setDataSessionChargePlan (dataSessionID : in TpSessionID, dataSessionChargePlan : in 
TpDataSessionChargePlan) : void 

setAdviceOfCharge (dataSessionID : in TpSessionID, aoClnfo : in TpAoClnfo, tariffSwitcin : in TpDuration) 
void 

deassignDataSession (dataSessionID : in TpSessionID) : void 

continueProcessing (dataSessionID : in TpSessionID) : void 



8.3.1 Method connectReqO 



This asynchronous method requests the connection of a data session with the destination party (specified in the 
parameter TargetAddress). The Data Session object is not automatically deleted if the destination party disconnects 
from the data session. 

Returns assignmentID : Specifies the ID assigned to the request. The same ID will be returned in the connectRes or Err. 
This allows the application to correlate the request and the result. 

Parameters 

dataSessionID : in TpSessionID 

Specifies the session ID. 

responseRequested : in TpDataSessionReportRequestSet 

Specifies the set of observed data session events that will result in a connectRes() being generated. 

targetAddress : in TpAddress 

Specifies the address of destination party. 

Returns 
TpAssignmentID 

Raises 

TpCommonExceptions, P_INVALID_NETWORK_STATE, P_INVALID_ADDRESS, 
P INVALID SESSION ID 
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8.3.2 Method releaseQ 

This method requests the release of the data session and associated objects. 

Parameters 

dataSessionID : in TpSessionID 

Specifies the session. 

cause : in TpDataSessionReleaseCause 

Specifies the cause of the release. 

Raises 

TpCommonExceptions, P_INVALID_NETWORK_STATE, P_INVALID_SESSION_ID 



8.3.3 Method superviseDataSessionReq() 

The application calls this method to supervise a data session. The application can set a granted data volume for this data 
session. If an application calls this function before it calls a connectReqO or a user interaction function the time 
measurement will start as soon as the data session is connected. The Data Session object will exist after the data session 
has been terminated if information is required to be sent to the apphcation at the end of the data session. 

Parameters 

dataSessionID : in TpSessionID 

Specifies the data session. 

treatment : in TpDataSessionSuperviseTreatment 

Specifies how the network should react after the granted data volume has been sent. 

bytes : in TpDataSessionSuperviseVolume 

Specifies the granted number of bytes that can be transmitted for the data session. 

Raises 

TpCommonExceptions, P_INVALID_NETWORK_STATE, P_INVALID_SESSION_ID 



8.3.4 Method setDataSessionChargePlan() 

Allows an application to include charging information in network generated CDR. 

Parameters 

dataSessionID : in TpSessionID 

Specifies the session ID of the data session. 

dataSessionChargePlan : in TpDataSessionChargePlan 

Specifies the charge plan used. 
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Raises 

TpCommonExceptions, P_INVALID_NETWORK_STATE, P_INVALID_SESSION_ID 



8.3.5 Method setAdviceOfCharge() 

This method allows the application to determine the charging information that will be sent to the end-users terminal. 

Parameters 

dataSessionID : in TpSessionID 

Specifies the session ID of the data session. 

aoCInfo : in TpAoCInfo 

Specifies two sets of Advice of Charge parameter according to GSM. 

tariffSwitch : in TpDuration 

Specifies the tariff switch that signifies when the second set of AoC parameters becomes valid. 

Raises 

TpCommonExceptions , P_INVALID_NETWORK_STATE , 
P INVALID TIME AND DATE FORMAT 



8.3.6 Method deassignDataSessionQ 



This method requests that the relationship between the application and the data session and associated objects be de- 
assigned. It leaves the data session in progress, however, it purges the specified data session object so that the 
application has no further control of data session processing. If a data session is de-assigned that has event reports, data 
session information reports requested, then these reports will be disabled and any related information discarded. 

The application should always either release or deassign the data session when it is finished with the data session, 
unless dataSessionFaultDetected is received by the application. 

Parameters 

dataSessionID : in TpSessionID 

Specifies the session ID of the data session. 

Raises 

TpCommonExceptions , P_INVALID_SESSION_ID 



8.3.7 Method continueProcessing() 



This operation continues processing of the data session. Applications can invoke this operation after session handling 
was interrupted due to detection of a notification or event the application subscribed its interest in. 
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Parameters 

dataSessionID : in TpSessionID 

Specifies the session ID of the data session. 

Raises 

TpCommonExceptions, P_INVALID_SESSION_ID, P_INVALID_NETWORK_STATE 



8.4 Interface Class IpDataSessionControlManager 

Inherits from: IpService. 

This interface is the 'SCF manager' interface for Data Session Control. This interface shall be implemented by a Data 
Session Control SCF. As a minimum requirement, the createNotifications() and destroyNotification(), or the 
enableNotificationsO and disableNotifications() methods shall be implemented. 



«lnterface» 
IpDataSessionControlManager 



«deprecated» createNotification (appDataSessionControlManager : in 

IpAppDataSessionControlManagerRef, eventCriteria : in TpDataSessionEventCriteria) : TpAssignmentID 

destroyNotification (assignmentID : in TpAssignmentID) : void 

changeNotification (assignmentID : in TpAssignmentID, eventCriteria : in TpDataSessionEventCriteria) : 
void 

enableNotifications (appDataSessionControlManager : in IpAppDataSessionControlManagerRef) : 
TpAssignmentID 

disableNotifications () : void 

getNotifications () : TpDataSessionEventCriteriaResultSet 

createNotifications (appDataSessionControlManager : in IpAppDataSessionControlManagerRef, 
eventCriteria : in TpDataSessionEventCriteria) : TpAssignmentID 



8.4.1 Method «deprecated» createNotification() 

This method is deprecated and will be removed in a later release. It is replaced with createNotifications(). 

This method is used to enable data session notifications so that events can be sent to the application. This is the first step 
an application has to do to get initial notifications of data session happening in the network. When such an event 
happens, the application will be informed by reportNotification(). In case the application is interested in other events 
during the context of a particular data session it has to use the connectReqO method on the data session object. The 
application will get access to the data session object when it receives the reportNotification(). 

The createNotification method is purely intended for applications to indicate their interest to be notified when certain 
data session events take place. It is possible to subscribe to a certain event for a whole range of addresses, e.g. the 
application can indicate it wishes to be informed when a data session is setup to any number starting with 800. 

If some application already requested notifications with criteria that overlap the specified criteria or the specified 
criteria overlap with criteria already present in the network (when provisioned from within the network), the request is 
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refused with P_INVALID_CRITERIA. The criteria are said to overlap if both originating and terminating ranges 
overlap and the same number plan is used. 

If a notification is requested by an application with monitor mode set to notify, then there is no need to check the rest of 
the criteria for overlapping with any existing request as the notify mode does not give control of a data session. Only 
one application can place an interrupt request if the criteria overlap. 

If the same application invokes this method multiple times with exactly the same criteria but with different callback 
references, then these shall be treated as additional callback references. Each such notification request shall share the 
same assignmentlD. The SCS shall use the most recent callback interface provided by the application using this method. 
In the event that a callback reference fails or is no longer available, the next most recent callback reference available 
shall be used. 

In case the createNotification contains no callback, at the moment the application needs to be informed the gateway will 
use as callback the callback that has been registered by setCallback(). 

Returns assignmentlD : Specifies the ID assigned by the Data Session Manager object for this newly-enabled event 
notification. 

Parameters 

appDataSessionControlManager : in IpAppDataSessionControlManagerRef 

If this parameter is set (i.e. not NULL) it specifies a reference to the application interface which is used for callbacks. If 
set to NULL, the application interface defaults to the interface specified via the setCallback() method. 

eventCriteria : in TpDataSessionEventCriteria 

Specifies the event specific criteria used by the application to define the event required. Individual addresses or address 
ranges may be specified for destination and/or origination. Examples of events are "Data Session set up". 

Returns 
TpAssignmentID 

Raises 

TpCommonExceptions, P_INVALID_NETWORK_STATE, P_INVALID_CRITERIA, 
P INVALID EVENT TYPE 



8.4.2 Method destroyNotification() 



This method is used by the application to disable data session notifications. This method only applies to notifications 
created with createNotification(). 

Parameters 

assignmentlD : in TpAssignmentID 

Specifies the assignment ID given by the data session manager object when the previous createNotification() was done. 

Raises 

TpCommonExceptions, P_INVALID_NETWORK_STATE, P_INVALID_ASSIGNMENT_ID 
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8.4.3 Method changeNotificationQ 



This method is used by the application to change the event criteria introduced with the createNotification method. Any 
stored notification request associated with the specified assignmentID will be replaced with the specified events 
requested. 

Parameters 

assignmentID : in TpAssignmentID 

Specifies the ID assigned by the manager interface for the event notification. 

eventCriteria : in TpDataSessionEventCriteria 

Specifies the new set of event criteria used by the application to define the event required. Only events that meet these 
criteria are reported. 

Raises 

TpCommonExceptions, P_INVALID_NETWORK_STATE, P_INVALID_ASSIGNMENT_ID, 
P_INVALID_CRITERIA, P_INVALID_EVENT_TYPE 



8.4.4 Method enableNotifications() 

This method is used to indicate that the application is able to receive which are provisioned from within the network 
(i.e. these notifications are NOT set using createNotification() but via, for instance, a network management system). If 
notifications provisioned for this application are created or changed, the application is unaware of this until the 
notification is reported. 

If the same application invokes this method multiple times with different IpAppDataSessionControlManager references, 
then these shall be treated as additional callback references. Each such notification request shall share the same 
assignmentID. The SCS shall use the most recent callback interface provided by the application using this method. In 
the event that a callback reference fails or is no longer available, the next most recent callback reference available shall 
be used. 

When this method is used, it is still possible to use createNotification() for service provider provisioned notifications on 
the same interface as long as the criteria in the network and provided by createNotification() do not overlap. However, it 
is NOT recommended to use both mechanisms on the same service manager. 

The methods changeNotification(), getNotifications(), and destroyNotification() do not apply to notifications 
provisioned in the network and enabled using enableNotifications(). These only apply to notifications created using 
createNotificationO . 

Returns assignmentID: Specifies the ID assigned by the manager interface for this operation. This ID is contained in 
any reportNotification() that relates to notifications provisioned from within the network. Repeated calls to 
enableNotificationsO return the same assignment ID. 

Parameters 

appDataSessionControlManager : in IpAppDataSessionControlManagerRef 

If this parameter is set (i.e. not NULL) it specifies a reference to the application interface, which is used for callbacks. If 
set to NULL, the application interface defaults to the interface specified via the setCallback() method. 
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Returns 

TpAs s ignment ID 

Raises 
TpCommonExceptions 

8.4.5 Method disableNotifications() 

This method is used to indicate that the application is not able to receive notifications for which the provisioning has 
been done from within the network, (i.e. these notifications that are NOT set using createNotification() but via, for 
instance, a network management system). After this method is called, no such notifications are reported anymore. 

Parameters 

No Parameters were identified for this method 

Raises 
TpCommonExceptions 



8.4.6 Method getNotifications() 

This method is used by the application to query the event criteria set with createNotification or changeNotification. 

Returns eventCriteria: the list of event criteria for the notifications requested by the application. If there is no 
information to return (e.g. no notifications requested by the application), an empty set (zero length) is returned. 

Parameters 

No Parameters were identified for this method 

Returns 
TpDataSessionEventCriteriaResultSet 

Raises 

TpCommonExceptions , P_INVALID_NETWORK_STATE 



8.4.7 Method createNotifications() 

This method is used to enable data session notifications so that events can be sent to the application. This is the first step 
an application has to do to get initial notifications of data session happening in the network. When such an event 
happens, the application will be informed by reportNotification(). In case the application is interested in other events 
during the context of a particular data session it has to use the connectReqO method on the data session object. The 
application will get access to the data session object when it receives the reportNotification(). 

The createNotification method is purely intended for applications to indicate their interest to be notified when certain 
data session events take place. It is possible to subscribe to a certain event for a whole range of addresses, e.g. the 
application can indicate it wishes to be informed when a data session is setup to any number starting with 800. 

If some application already requested notifications with criteria that overlap the specified criteria or the specified 
criteria overlap with criteria already present in the network (when provisioned from within the network), the request is 
refused with P_INVALID_CRITERIA. The criteria are said to overlap if both originating and terminating ranges 
overlap and the same number plan is used. 
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If a notification is requested by an application with monitor mode set to notify, then there is no need to check the rest of 
the criteria for overlapping with any existing request as the notify mode does not give control of a data session. Only 
one application can place an interrupt request if the criteria overlap. 

If the same application invokes this method multiple times with exactly the same criteria but with different callback 
references, then these shall be treated as additional callback references. Each such notification request shall share the 
same assignmentlD. The SCS shall use the most recent callback interface provided by the application using this method. 
In the event that a callback reference fails or is no longer available, the next most recent callback reference available 
shall be used. 

In case the createNotification contains no callback, at the moment the application needs to be informed the gateway will 
use as callback the callback that has been registered by setCallbackQ. 

Returns assignmentlD : Specifies the ID assigned by the Data Session Manager object for this newly-enabled event 
notification. 

Parameters 

appDataSessionControlManager : in IpAppDataSessionControlManagerRef 

If this parameter is set (i.e. not NULL) it specifies a reference to the application interface which is used for callbacks. If 
set to NULL, the application interface defaults to the interface specified via the setCallback() method. 

eventCriteria : in TpDataSessionEventCriteria 

Specifies the event specific criteria used by the application to define the event required. Individual addresses or address 
ranges may be specified for destination and/or origination. Examples of events are "Data Session set up". 

Returns 

TpAs s ignment ID 

Raises 

TpCommonExceptions, P_INVALID_NETWORK_STATE, P_INVALID_CRITERIA, 
P_INVALID_EVENT_TYPE , P_INVALID_INTERFACE_TYPE 



9 State Transition Diagrams 

9.1 State Transition Diagrams for IpDataSession 

The state transition diagram shows the application view on the Data Session object. 
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Figure : Application view on the Data Session object 

9.1 .1 Network Released State 

In this state the data session has ended. In the case on a normal user disconnection the transition to this state is indicated 
to the application by the disconnect report of connectRes(). But this will only happen if the application requested 
monitoring of the disconnect event before. An abnormal disconnection is indicated by dataSessionFaultDetected(). The 
application may wait for outstanding superviseDataSessionRes(). 

9.1.2 Finished State 

In this state the data session has ended and no further data session related information is to be send to the application. 
The application can only release the data session object. Calling the deassignDataSession() operation has the same 
effect. If the application fails to invoke release() within a certain period of time the gateway should automatically 
release the object and send a timeout indication to the application. 

9.1 .3 Application Released State 

In this state the application has released the data session object. If supervision has been requested the gateway will 
collect the information and send superviseDataSessionRes() to the application. 

9.1.4 Active State 

In this state a data connection between two parties is being setup or established (refer to the substates for more details). 
The application can request the gateway for a certain type of charging by calling setDataSessionChargePlan(), send 
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advice of charge information by calling setAdviceOfCharge(), and request supervision of the data session by calling 
superviseDataSessionReqO. 

9.1.5 Setup State 

The Setup state is reached after a reportNotification() indicates to the application that a data session is interested in 
being connected. If the application is going to connect the two parties by invoking connectReqO it may call the 
charging or supervision methods before. 

9.1.6 Established State 

In this state the data connection is established. If supervision has been requested the application expects the 
corresponding superviseDataSessionRes(). 



1 Data Session Control Service Properties 

The following table lists properties relevant for the Data Session Control API. 



Property 


Type 


Description/Interpretation 


P„TRIGGERING_EVENT_TYPES 


INTEGER_SET 


Indicates the static event types supported by tiie SCS. Static 
events are the events by which applications are initiated. 


P_DYNAMIC_EVENT_TYPES 


INTEGER_SET 


Indicates the dynamic event types supported by the SCS. 
Dynamic events are the events the application can request 
for during the context of a call. 


P_ADDRESSPLAN 


INTEGER_SET 


Indicates the supported address plans (defined in 
TpAddressPlan.) E.g. P„ADDRESS_PLAN_1P. Note that 
more than one address plan may be supported. 



The previous table lists properties related to the capabilities of the SCS itself. The following table lists properties that are 
used in the context of the Service Level Agreement, e.g. to restrict the access of applications to the capabilities of the 
SCS. 
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Property 


Type 


Description/Interpretation 


P_NOTIFICATION_ADDRESS_RANGES 


XML_ADDRESS_RANGE_ 

SET 


Indicates for which numbers notifications may be set. More 
than one range may be present. For terminating notifications 
they apply to the terminating number, for originating 
notifications they apply only to the originating number. 


P_MONITOR^MODE 


INTEGER_SET 


Indicates whether the application is allowed to monitor in 
interrupt and/or notify mode. Set is: 

P_INTERRUPT 

P_NOTIFY 


P_NUMBERS_TO_BE_CHANGED 


INTEGER_SET 


Indicates which numbers the application is allowed to 
change or fill for legs in an incoming call. Allowed value 
set: 

{ P_TARGET_NUMBER ) . 


P_CHARGEPLAN_ALLOWED 


INTEGER.SET 


Indicates which charging is allowed in the 
setDataSessionChargePlan indicator. Allowed values: 

{ P_CHARGE_PER_VOLUME, 
P_TRANSPARANT_CHARGING, 

P_CHARGE_PLAN) 


P_CHARGEPLAN_MAPPING 


INTEGER_INTEGER_MAP 


Indicates the mapping of charge plans (we assume they can 
be indicated with integers) to a logical network charge plan 
indicator. When the P_CHARGEPLAN_ALLOWED 
property indicates P__CHARGE_PLAN, then only charge 
plans in this mapping are allowed. 


P_CURRENCY_ALLOWED 


STRING_SET 


Indicates the currencies that are allowed to be set for the 
charge plan in the setDataSessionChargePlan. The vaUd 
values for the string set are according to ISO-4217. E.g. 
{'EUR, 'NLG). 



11 



Data Definitions 



All data types referenced but not defined in this clause are common data definitions which may be found in 
3GPPTS 29.198-2. 



11.1 Data Session Control Data Definitions 



11.1.1 IpAppDataSession 

Defines the address of an IpAppDataSession Interface. 

11.1.2 IpAppDataSessionRef 

Defines a Reference to type IpAppDataSession 

11.1.3 IpAppDataSessionControlManager 

Defines the address of an IpAppDataSessionControlManager Interface. 

11.1.4 IpAppDataSessionControlManagerRef 

Defines a Reference to type IpAppDataSessionControlManager. 



11.1.5 IpDataSession 

Defines the address of an IpDataSession Interface. 
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11.1.6 IpDataSessionRef 

Defines a Reference to type IpDataSession. 

11.1.7 IpDataSessionControlManager 

Defines the address of an IpDataSessionControlManager Interface. 

11.1.8 IpDataSessionControlManagerRef 

Defines a Reference to type IpDataSessionControlManager. 

1 1 .2 Event Notification data definitions 
1 1 .2.1 TpDataSessionEventName 

Defines the names of events being notified with a new call request. The following events are supported. The values may 
be combined by a logical 'OR' function when requesting the notifications. Additional events that can be requested / 
received during the call process are found in the TpDataSessionReportType data-type. 



Name 


Value 


Description 


P_EVENT_NAME_UNDEFINED 





Undefined 


P_EVENT_DSCS_SETUP 


1 


The data session is going to be setup. 


P_EVENT_DSCS_ESTABLISHED 


2 


The data session is established by the network. 


P_EVENT_DSCS_QOS_CHANGED 


4 


A change in QoS class has taken place during 
the life of the data session. 



1 1 .2.2 TpDataSessionlVlonitorlVlode 



Defines the mode that the call will monitor for events, or the mode that the call is in following a detected event. 



Name 


Value 


Description 


P_DATA_SESSION_MONITOR_MODE_INTERRUPT 





The data session event is intercepted by the data session control 

service and data session estabhshment is interrupted. The 

appUcation is notified of the event and data session estabhshment 

resumes following an appropriate API call or network event (such 

as a data session release) 


P_DATA_SESSION_MONITOR_MODE_NOTIFY 


1 


The data session event is detected by the data session control 

service but not intercepted. The apphcation is notified of the event 

and data session establishment continues 


P_DATA_SESSION_MONITOR_MODE_DO_NOT_MONITOR 


2 


Do not monitor for the event 



1 1 .2.3 TpDataSessionEventCriteria 

Defines the Sequence of Data Elements that specify the criteria for a event notification. 

Of the addresses only the Plan and the AddrString are used for the purpose of matching the notifications against the 
criteria. 
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Sequence Element Name 


Sequence Element Type 


Description 


DestinationAddress 


TpAddressRange 


Defines the destination address or address range for which the 
notification is requested. 


OriginationAddress 


TpAddressRange 


Defines the origination address or a address range for which the 
notification is requested. 


DataSessionEventName 


TpDataSessionE vent Name 


Name of the event(s) 


MonitorMode 


TpDataSessionMonitorMode 


Defines the mode that the Data Session is in following the 

notification. 

Monitor mode 

P_DATA_SESSION_MONITOR_MODE_DO_NOT_MONITOR 

is not a legal value here. 



1 1 .2.4 TpDataSessionEventlnfo 



Defines the Sequence of Data Elements that specify the information returned to the appUcation in a Data Session 
event notification. 



Sequence Element Name 


Sequence Element Type 


Description 


DestinationAddress 


TpAddress 


Defines the destination address for which the notification is 
reported. 


OriginatingAddress 


TpAddress 


Defines the origination address for which the notification is 
reported. 


DataSessionEventName 


TpDataSessionEventName 


Name of the event(s). 


MonitorMode 


TpDataSessionMonitorMo 
de 


Defines the mode in which the Data Session is reporting the 

notification. 

Monitor mode 

P_DATA_SESSION_MONITOR„MODE„DO_NOT_MONITOR 

is not a legal value here. 


QoSClass 


TpDataSessionQosClass 


Defines the Quality of Service (QoS) class for the Data Session. 

QoSClass NULL is not a legal value when DataSessionEventName 

is set to P„EVENT_DSCS_QOS_CHANGED. For this particular 

event, the QoSClass defines the new QoS class effective after the 

change. 



1 1 .2.5 TpDataSessionChargePlan 

Defines the Sequence of Data Elements that specify the charge plan for the call. 



Sequence Element Name 


Sequence Element Type 


Description 


ChargeOrderType 


TpDataSessionChargeOrder 


Charge order 


Currency 


TpString 


Currency unit according to lSO-4217 [4] 


Additional Info 


TpString 


Descriptive string which is sent to the billing system without prior 
evaluation. Could be included in the ticket. 



Valid Currencies are: 

ADP, AED, AFA, ALL, AMD, ANG, AON, AOR, ARS, ATS, AUD, AWG, AZM, BAM, 

BBD, BDT, BEE, BGL, BGN, BHD, BIF, BMD, BND, BOB, BOV, BRL, BSD, BTN, 

BWP, BYB, BZD, CAD, CDF, CHE, CLE, CLP, CNY, COP, CRC, CUP, CVE, CYP, 

CZK, DEM, DJE, DKK, DOP, DZD, ECS, ECV, EEK, EGP, ERN, ESP, ETB, EUR, 

FIM, FJD, FKP, FRF, GBP, GEL, GHC, GIP, GMD, GNF, GRD, GTQ, GWP, GYD, 

HKD, HNL, HRK, HTG, HUE, IDR, lEP, ILS, INR, IQD, IRR, ISK, ITL, JMD, 

JOD, JPY, KES, KGS, KHR, KMF, KPW, KRW, KWD, KYD, KZT, LAK, LBP, LKR, 

LRD, LSL, LTL, LUF, LVL, LYD, MAD, MDL, MGF, MKD, MMK, MNT, MOP, MRO, 

MTL, MUR, MVR, MWK, MXN, MXV, MYR, MZM, NAD, NGN, NIO, NLG, NOK, NPR, 

NZD, OMR, PAB, PEN, PGK, PHP, PKR, PEN, PTE, PYG, QAR, ROL, RUB, RUR, 
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RWF, SAR, SBD, SCR, SDD, SEK, SGD, SHP, SIT, SKK, SLL, SOS, SRG, STD, 
SVC, SYP, SZL, THB, TJR, TMM, TND, TOP, TPE, TRL, TTD, TWD, TZS, UAH, 
UGX, USD, USN, USS, UYU, UZS, VEB, VND, VUV, WST, XAF, XAG, XAU, XBA, 
XBB, XBC, XBD, XCD, XDR, XFO, XFU, XOF, XPD, XPF, XPT, XTS, XXX, YER, 
YUM, ZAL, ZAR, ZMK, ZRN, ZWD. 
XXX is used for transactions where no currency is involved. 

1 1 .2.6 TpDataSessionChargeOrder 

Defines the Tagged Choice of Data Elements that specify the charge plan for the call. 





Tag Element Type 






TpDataSessionChargeOrder Category 





Tag Element Value 


Choice Element Type 


Choice Element Name 


P_DATA_SESSION_CHARGE_PER_VOLUME 


TpChargePerVolume 


ChargePerVolume 


P_DATA_SESSION_CHARGE_NETWORK 


TpString 


NetworkCharge 



1 1 .2.7 TpDataSessionChargeOrderCategory 



Name 


Value 


Description 


P_DATA_SESSION_CHARGE_PER_VOLUME 





Charge per volume 


P_DATA_SESSION_CHARGE_NETWORK 


1 


Operator specific charge plan specification, e.g. charging table name / 
charging table entry 



11.2.8 TpChargePerVolume 



Defines the Sequence of Data Elements that specify the time based charging information. The volume is the sum of 
uplink and downlink transfer data volumes. 



Sequence Element Name 


Sequence Element Type 


Description 


InitialCharge 


Tplnt32 


Initial charge amount (in currency units * 0.0001) 


Cur rent Char gePerKilobyte 


Tplnt32 


Current tariff (in currency units * 0.0001) 


Next Char gePerKilobyte 


Tplnt32 


Next tariff (in currency units * 0.0001) after tariff switch. 
Only used in setAdviceOfCharge() 



1 1 .2.9 TpDataSessionldentifier 

Defines the Sequence of Data Elements that unambiguously specify the Data Session object. 



Sequence Element Name 


Sequence Element Type 


Sequence Element Description 


DataSessionRef erence 


IpDataSessionRef 


This element specifies the interface reference for the Data 
Session object. 


DataSessionID 


TpSessionID 


This element specifies the data session ID of the Data Session. 
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11.2.10 TpDataSessionError 

Defines the Sequence of Data Elements that specify the additional information relating to a call error. 



Sequence Element Name 


Sequence Element Type 


ErrorTime 


TpDateAndTime 


ErrorType 


TpDataSessionError Type 


AdditionalErrorInf o 


TpDataSessionAdditionalErrorlnfo 



1 1 .2.1 1 TpDataSessionAdditionalErrorlnfo 

Defines the Tagged Choice of Data Elements that specify additional Data Session error and Data Session error 
specific information. 





Tag Element Type 






TpDataSessionErrorType 






Tag Element Value 


Choice Element Type 


Choice Element Name 


P_DATA_SESSION_ERROR_UNDEFINED 


NULL 


Undefined 


P_DATA_SESSION_ERROR_INVALID_ADDRESS 


TpAddressError 


DataSessionErrorlnvalidAddress 


P_DATA_SESSION_ERROR_INVALID_STATE 


NULL 


Undefined 



1 1 .2.1 2 TpDataSessionErrorType 

Defines a specific Data Session error. 



Name 


Value 


Description 


P_DATA_SESSION_ERROR_UNDEFINED 





Undefined; the method failed or was refused, but no specific reason can be 

given. 


P_DATA_SESSION_ERROR_INVALID_ADDRESS 


1 


The operation failed because an invalid address was given 


P_DATA_SESSION_ERROR_INVALID_STATE 


2 


The data session was not in a valid state for the requested operation 



11.2.13 TpDataSessionFault 

Defines the cause of the data session fault detected. 



Name 


Value 


Description 


P_DATA_SESSION_FAULT_UNDEFINED 





Undefined 


P_DATA_SESSION_FAULT_USER_ABORTED 


1 


User has finahsed the data session before any message could be sent by the 
appUcation 


P_DATA_SESSION_TIMEOUT_ON_RELEASE 


2 


This fault occurs when the final report has been sent to the appUcation, but 

the application did not explicitly release data session object, within a 

specified time. 

The timer value is operator specific. 


P_DATA_SESSION_TIMEOUT_ON_INTERRUPT 


3 


This fault occurs when the application did not instruct the gateway how to 

handle the call within a specified time, after the gateway reported an event 

that was requested by the application in interrupt mode. 

The timer value is operator specific. 
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11 .2.1 4 TpDataSessionReleaseCause 

Defines the Sequence of Data Elements that specify the cause of the release of a data session. 



Sequence Element Name 


Sequence Element Type 


Value 


Tplnt32 


Location 


Tplnt32 


NOTE: The Value and Location are specified as in ITU-T Recommendation Q.850. | 



11.2.15 TpDataSessionSuperviseVolume 



Defines the Sequence of Data Elements that specify the amount of volume that is allowed to be transmitted for the 
specific connection. 



Sequence Element 
Name 


Sequence Element 
Type 


Sequence Element Description 


VolumeQuantity 


TDlnt32 


This data type is identical to a Tplnt32, and defines the quantity of the granted volume that 

can be transmitted for the specific connection. The volume specifies the sum of uplink and 

downlink transfer data volumes. 


VolumeUnit 


TDlnt32 


In Order to enlarge the range of the volume quantity value the exponent of a scahng factor 

(10'^ VolumeUnit) is provided. 

When the unit is for example in kilobytes, VolumeUnit shall be set to 3. 



11.2.16 TpDataSessionSuperviseReport 

Defines the responses from the data session control service for calls that are supervised. The values may be combined 
by a logical 'OR' function. 



Name 


Value 


Description 


P_DATA_SESSION_SUPERVISE_VOLUME_REACHED 


Olh 


The maximum volume has been reached. 


P_DATA_SESSION_SUPERVISE_DATA_SESSION_ENDED 


02h 


The data session has ended, either due to data 

session party to reach of maximum volume or 

calling or called release. 


P_DATA_SESSION_SUPERVISE_MESSAGE_SENT 


04h 


A warning message has been sent. 



11.2.17 TpDataSessionSuperviseTreatment 



Defines the treatment of the call by the data session control service when the supervised volume is reached. The values 
may be combined by a logical 'OR' function. 



Name 


Value 


Description 


P_DATA_SESSION_SUPERVISE_RELEASE 


01h 


Release the data session when the data session supervision volume is reached. 


P_DATA_SESSION_SUPERVISE_RESPOND 


02h 


Notify the application when the call supervision volume is reached. 


P_DATA_SESSION_SUPERVISE_INFORM 


04h 


Send a warning message to the originating party when the maximum volume 

is reached. If data session release is requested, then the data session will be 

released following the message after an administered time period. 



11.2.18 TpDataSessionReport 

Defines the Sequence of Data Elements that specify the data session report specific information. 



Sequence Element Name 


Sequence Element Type 


MonitorMode 


TpDataSessionMonitorMode 


DataSessionE vent Time 


TpDateAndTime 


DataSessionReportType 


TpDataSessionReport Type 


AdditionalReportInf o 


TpDataSessionAdditionalReportInf o 
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11 .2.1 9 TpDataSessionAdditionalReportlnfo 



Defines the Tagged Choice of Data Elements that specify additional data session report information for certain types of 
reports. 





Tag Element Type 






TpDataSessionReportType 





Tag Element Value 


Choice Element Type 


Choice Element Name 


P_DATA_SESSION_REPORT_UNDEFINED 


NULL 


Undefined 


P_DATA_SESSION_REPORT_CONNECTED 


NULL 


Undefined 


P_DATA_SESSION_REPORT_DISCONNECT 


TpDataSessionReleaseCause 


DataSessionDisconnect 



1 1 .2.20 TpDataSessionReportRequest 

Defines the Sequence of Data Elements that specify the criteria relating to data session report requests. 



Sequence Element Name 


Sequence Element Type 


MonitorMode 


TpDataSessionMonitorMode 


DataSessionReportType 


TpDataSessionReportType 



1 1 .2.21 TpDataSessionReportRequestSet 

Defines a Numbered Set of Data Elements of TpDataSessionReportRequest. 

1 1 .2.22 TpDataSessionReportType 

Defines a specific data session event report type. 



Name 


Value 


Description 


P_DATA_SESSION_REPORT_UNDEFINED 





Undefined 


P_DATA_SESSION_REPORT_CONNECTED 


1 


Data session established. 


P_DATA_SESSION_REPORT_DISCONNECT 


2 


Data session disconnect requested by data session party 



1 1 .2.23 TpDataSessionEventCriteriaResult 

Defines a sequence of data elements that specify a requested data session event notification criteria with the associated 
assignmentlD. 



Sequence Element Name 


Sequence Element Type 


Sequence Element Description 


Event Criteria 


TpDataSessionEventCriteria 


The event criteria that were specified by the application. 


AssignmentlD 


TpAssignmentID 


The associated assignmentlD. This can be used to disable the 
notification. 



1 1 .2.24 TpDataSessionEventCriteriaResultSet 

Defines a set of TpDataSessionEventCriteriaResult. 



£75/ 



3GPP TS 29.1 98-08 version 6.4.0 Release 6 39 ETSI TS 1 29 1 98-8 V6.4.0 (2005-1 2) 

Annex A (normative): 

OMG IDL Description of Data Session Control SCF 

The OMG IDL representation of this interface specification is contained in a text file (dsc.idl contained in archive 
2919808V640IDL.ZIP) which accompanies the present document. 
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Annex B (informative): 

W3C WSDL Description of Data Session Control SCF 

Significant changes have occurred in Web Services technologies and understanding of how to best apply Web Services 
as a realisation of OS A. These changes are not reflected and therefore this realisation is removed. A future activity may 
provide a replacement for the content of this annex, reflective of current technology and usage expected. 
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Annex C (informative): 

Java™ API Description of the Data Session Control SCF 

The JavaT"^ API realisation of this interface specification is produced in accordance with the Java''^ ReaHsation rules 
defined in Part 1 of this specification series. These rules aim to deliver for Java'''^, a developer API, provided as a 
realisation, supporting a Java'^ API that represents the UML specifications. The rules support the production of both 
J2SE'''^ and J2EEr'^ versions of the API from the common UML specifications. 

The J2SE''^ representation of this interface specification is provided as Java'"*^ Code, contained in archive 
2919808V640J2SE.ZIP that accompanies the present document. 

The J2EE''''^ representation of this interface specification is provided as Java"^ Code, contained in archive 
2919808V640J2EE.ZIP that accompanies the present document. 
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Annex D (informative): 

Description of Data Session Control for 3GPP2 cdma2000 

networks 

This annex is intended to define the OSA API Stage 3 interface definitions and it provides the complete OSA 
specifications. It is an extension of OSA API specifications capabilities to enable operation in cdma2000 systems 
environment. They are in alignment with 3GPP2 Stage 1 requirements and Stage 2 architecture defined in: 

[1] 3GPP2 P.SOOOl-B: "Wireless IP Network Standard", Version 1.0, September 2000. 

[2] 3GPP2 S.R0037-0: "IP Network Architecture Model for cdma2000 Spread Spectrum Systems", 

Version 2.0, May 14, 2002. 

[3] 3GPP2 X.S0013: "All-IP Core Network Multimedia Domain", December 2003. 

These requirements are expressed as additions to and/or exclusions from the 3GPP Release 6 specification. 

The information given here is to be used by developers in 3GPP2 cdma2000 network architecture to interpret the 3GPP 

OSA specifications. 



D.1 General Exceptions 



The term UMTS is not applicable for the cdma2000 family of standards. Nevertheless these terms are used (3GPP TR 
21.905) mostly in the broader sense of "3G Wireless System". If not stated otherwise there are no additions or 
exclusions required. 

CAMEL and CAP mappings are not applicable for cdma2000 systems. 



D.2 Specific Exceptions 
D.2.1 Clause 1: Scope 

There are no additions or exclusions. 

D.2.2 Clause 2: References 

Normative references on 3GPP TS 23.078 and on 3GPP TS 29.078 are not applicable for cdma2000 systems. 

D.2. 3 Clause 3: Definitions and abbreviations 

There are no additions or exclusions. 

D.2.4 Clause 4: Data Session Control SCF 

There are no additions or exclusions. GPRS and PDP context are not applicable for cdma2000 systems. 

D.2. 5 Clause 5: Sequence Diagrams 

There are no additions or exclusions. GPRS and PDP context are not applicable for cdma2000 systems. 
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D.2.6 Clause 6 Class Diagrams 

There are no additions or exclusions. GPRS and PDP context are not applicable for cdma2000 systems. 

D.2.7 Clause 7: The Service Interface Specifications 

There are no additions or exclusions. GPRS and PDP context are not applicable for cdma2000 systems. 

D.2.8 Clause 8: Data Session Control Interface Classes 

There are no additions or exclusions. GPRS and PDP context are not applicable for cdma2000 systems. 

D.2.9 Clause 9: State Transition Diagrams 

There are no additions or exclusions. GPRS and PDP context are not applicable for cdma2000 systems. 

D.2.10 Clause 10: Data Session Control Service Properties 

There are no additions or exclusions. GPRS and PDP context are not applicable for cdma2000 systems. 

D.2.1 1 Clause 1 1 : Data Definitions 

There are no additions or exclusions. GPRS and PDP context are not applicable for cdma2000 systems. 

D.2.1 2 Annex A (normative): OMG IDL Description of Data Session 
Control SCF 

There are no additions or exclusions. 

D.2.1 3 Annex B (informative): W3C WSDL Description of Data 
Session Control SCF 

There are no additions or exclusions. 
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Annex E (informative): 
Change history 



Change history 


Date 


TSG# 


TSG Doc. 


CR 


Rev 


Subject/Comment 


Old 


New 


Mar 2001 


CN 11 


NP-010134 
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- 


CR 29.198: for moving TS 29.198 from R99 to Rel 4 (N5-010158) 


3.2.0 


1.0.0 


Jun2001 


CN 12 


NP-010330 


001 


- 


Corrections to OSA API Rel4 


4.0.0 


4.1.0 


Sep 2001 


CN 13 


NP-0 10471 


002 


- 


Clianging references to JAIN 


4.1.0 


4.2.0 


Dec 2001 


CN 14 


NP-010601 


003 


- 


Replace Out Parameters with Return Types 


4.2.0 


4.3.0 


Dec 2001 


CN 14 


NP-010601 


004 


- 


Corrections and alignment additions to the Data Session Control SCF 


4.2.0 


4.3.0 


Mar 2002 


CN_15 


NP-020110 


005 


— 


Add P_INVALID_INTERFACE_TYPE exception to 
IpService.setCallbackO and lpService.setCallbackWithSessionlD() 


4.3.0 


4.4.0 


Jun 2002 


CN 16 


NP-020182 


006 


- 


Addition of support for WSDL realisation 


4.4.0 


5.0.0 


Jun 2002 


CN 16 


NP-020183 


007 


- 


Addition of Support for Network Controlled Notifications DSC 


4.4.0 


5.0.0 


Jun 2002 


CN 16 


NP-020192 


008 


- 


Adding missing text concerning the activity timer and criteria overlap 


4.4.0 


5.0.0 


Sep 2002 


CN_17 


NP-020435 


Oil 




Remove duplicate exception from 
IpDataSessionControlManager.createNotificationO 


5.0.0 


5.1.0 


Sep 2002 


CN_17 


NP-020435 


012 




Remove P SERVICE INFORMATION MISSING and 
P_SERVICE_FAULT_ENCOUNTERED exceptions 
from DataSessionControl methods. 


5.0.0 


5.1.0 


Sep 2002 


CN_17 


NP-020435 


013 




Introduce new method getNotifications to correct the result type of 
IpDataSessionControlManager.getNotificationO to permit retreival of 
all created notifications. 


5.0.0 


5.1.0 


Sep 2002 


CN_17 


NP-020435 


014 




Add P_INVALID_INTERFACE_TYPE exception to 
IpDataSessionControlManager.createNotificationO, resulting in new 
createNotificationsO method 


5.0.0 


5.1.0 


Sep 2002 


CN 17 


NP-020435 


015 




Add text to clarify requirements on support of methods 


5.0.0 


5.1.0 


Sep 2002 


CN 17 


NP-020435 


016 




Correction on use of NULL in Data Session Control API 


5.0.0 


5.1.0 


Sep 2002 


CN_17 


NP-020395 


017 




Add text to clarify relationship between 3GPP and ETSI/Parlay OSA 
specifications 


5.0.0 


5.1.0 


Mar 2003 


CN 19 


NP-030024 


019 


- 


Addition of status of methods to Data Session Control interfaces 


5.1.0 


5.2.0 


Mar 2003 


CN 19 


NP-030024 


021 


- 


Corrections to data types in Data Session Control 


5.1.0 


5.2.0 


Mar 2003 


CN 19 


NP-030034 


022 


- 


Inconsistent description of use of secondary callback 


5.1.0 


5.2.0 


Mar 2003 


CN_19 


NP-030034 


023 


- 


Promotion of TpDataSessionQosClass data type definition to the 
Common Data Types 


5.1.0 


5.2.0 
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